package com.fowo.api.inventory.model;

import com.alibaba.excel.annotation.ExcelProperty;
import com.fowo.api.common.validator.*;
import javax.validation.constraints.*;
import lombok.Data;

/** 库存变动表 预览导入辅助模型(全字段为文本类型) */
@Data
public class InventoryVariationImportPo {

  /** 仓库内码 */
  @ExcelProperty("*仓库内码")
  @NotBlank(message = "仓库内码不能为空")
  @IntegerString(message = "仓库内码数值格式不正确", label = "仓库内码")
  private String stockId;

  /** 项目内码 */
  @ExcelProperty("项目内码")
  @IntegerString(message = "项目内码数值格式不正确", label = "项目内码")
  private String projectId;

  /** 物料内码 */
  @ExcelProperty("*物料内码")
  @NotBlank(message = "物料内码不能为空")
  @IntegerString(message = "物料内码数值格式不正确", label = "物料内码")
  private String itemId;

  /** 批号 */
  @ExcelProperty("批号")
  @Size(max = 50, message = "批号长度不能超过50")
  private String batchNo;

  /** 变动类型 */
  @ExcelProperty("*变动类型")
  @NotBlank(message = "变动类型不能为空")
  @Size(max = 10, message = "变动类型长度不能超过10")
  private String changeType;

  /** 变动源类型 */
  @ExcelProperty("变动源类型")
  @Size(max = 10, message = "变动源类型长度不能超过10")
  private String fromType;

  /** 变动目标类型 */
  @ExcelProperty("变动目标类型")
  @Size(max = 10, message = "变动目标类型长度不能超过10")
  private String toType;

  /** 关联单据号 */
  @ExcelProperty("关联单据号")
  @Size(max = 50, message = "关联单据号长度不能超过50")
  private String formNum;

  /** 关联制单人 */
  @ExcelProperty("关联制单人")
  @Size(max = 50, message = "关联制单人长度不能超过50")
  private String formOperator;

  /** 操作业务名称 */
  @ExcelProperty("*操作业务名称")
  @NotBlank(message = "操作业务名称不能为空")
  @Size(max = 50, message = "操作业务名称长度不能超过50")
  private String operate;

  /** 关联唯一操作键 */
  @ExcelProperty("关联唯一操作键")
  @Size(max = 50, message = "关联唯一操作键长度不能超过50")
  private String operateKey;

  /** 操作时间 */
  @ExcelProperty("操作时间")
  @DateTimeString(message = "操作时间不是有效的时间日期格式")
  private String operateTime;

  /** 库存数量 */
  @ExcelProperty("库存数量")
  @DecimalString(message = "库存数量小数格式不正确", label = "库存数量")
  private String stockQty;

  /** 库存金额 */
  @ExcelProperty("库存金额")
  @DecimalString(message = "库存金额小数格式不正确", label = "库存金额")
  private String stockAmount;

  /** 辅助数量 */
  @ExcelProperty("辅助数量")
  @DecimalString(message = "辅助数量小数格式不正确", label = "辅助数量")
  private String auxQty;

  /** 锁库数量 */
  @ExcelProperty("锁库数量")
  @DecimalString(message = "锁库数量小数格式不正确", label = "锁库数量")
  private String lockQty;

  /** 陈列数量 */
  @ExcelProperty("陈列数量")
  @DecimalString(message = "陈列数量小数格式不正确", label = "陈列数量")
  private String displayQty;

  /** 残次数量 */
  @ExcelProperty("残次数量")
  @DecimalString(message = "残次数量小数格式不正确", label = "残次数量")
  private String defectQty;

  /** 在途数量 */
  @ExcelProperty("在途数量")
  @DecimalString(message = "在途数量小数格式不正确", label = "在途数量")
  private String wayQty;
}
